﻿Imports DTO
Imports DAO
Imports BUS

Public Class frmCapNhatChucVu : Inherits DevComponents.DotNetBar.Office2007Form

    ' Hàm reset
    Private Sub Reset()
        'txtTenBangCap.Text = ""
        txtMaChucVu.Text = ""
        txtTenChucVuMoi.Text = ""
    End Sub

    ' Hàm kiểm tra dữ liệu khi thêm
    Private Function KiemTraDuLieuThem() As Boolean
        Return txtTenChucVu.Text <> ""
    End Function

    ' Khi nhấn nút Thoát
    Private Sub btnThoat_Click(ByVal sender As System.Object, ByVal e As System.EventArgs)
        Me.Close()
    End Sub

    ' Hàm thực hiện thêm bằng cấp
    Private Sub btnThem_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnThem.Click
        If KiemTraDuLieuThem() Then
            Dim kt As Integer = New CChucVuBUS().ThemChucVu(txtTenChucVu.Text)
            If (kt = (-1)) Then
                MessageBox.Show("Số chức vụ không được vượt quá số lượng quy định", "Thong Bao")
                txtTenChucVu.Text = ""
                Return
            Else
                If (kt = 0) Then
                    MessageBox.Show("Tên chức vụ này đã tồn tại!", "Thong Bao")
                    txtTenChucVu.Text = ""
                    Return
                Else
                    MessageBox.Show("Đã thêm thành công!", "Thong Bao")
                    txtTenChucVu.Text = ""
                    Dim listchucvu As List(Of CChucVuDTO) = New CChucVuBUS().LoadDanhSachChucVu()
                    dgvDanhSachChucVu.Rows.Clear()
                    stt = 1
                    For Each chucvu As CChucVuDTO In listchucvu
                        dgvDanhSachChucVu.Rows.Add(stt, chucvu.Ma, chucvu.Ten)
                        stt += 1
                    Next
                    Return
                End If
            End If
        Else
            MessageBox.Show("Dữ liệu không hợp lệ!", "Thong Bao")
            txtTenChucVu.Focus()
            Return
        End If

    End Sub

    Private stt As Integer

    ' Hàm load
    Private Sub frmCapNhatChucVu_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        stt = 1
        dtiNgayHienTai.Value = DateTime.Now
        ' Load danh sách bằng cấp vào trong datagridview:
        Dim listchucvu As List(Of CChucVuDTO) = New CChucVuBUS().LoadDanhSachChucVu()
        dgvDanhSachChucVu.Rows.Clear()
        For Each chucvu As CChucVuDTO In listchucvu
            dgvDanhSachChucVu.Rows.Add(stt, chucvu.Ma, chucvu.Ten)
            stt += 1
        Next
    End Sub


    ' Xử lý khi chọn vào dòng nào trong datagridview thì ta load nó lên cập nhật:
    Private Sub dgvDanhSachChucVu_CellClick(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles dgvDanhSachChucVu.CellClick
        Dim index As Integer = e.RowIndex
        If index < 0 Then
            If txtMaChucVu.Text <> "" Then
                Reset()
            End If
            Return
        End If

        If (index >= dgvDanhSachChucVu.Rows.Count) Then
            If (txtMaChucVu.Text <> "") Then
                Reset()
            End If
            Return
        End If

        Dim dr As DataGridViewRow = dgvDanhSachChucVu.Rows(index)
        txtMaChucVu.Text = dr.Cells("clMaChucVu").Value
        txtTenChucVuMoi.Text = dr.Cells("clTenChucVu").Value

    End Sub


    Private Sub btnCapNhat_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnCapNhat.Click
        Dim chucvu As New CChucVuDTO()
        If (Not Integer.TryParse(txtMaChucVu.Text, chucvu.Ma)) Then
            MessageBox.Show("Cần chọn chức vụ muốn cập nhật!", "Thong Bao")
            Return
        End If
        If (txtTenChucVuMoi.Text = "") Then
            MessageBox.Show("Cần nhập tên chức vụ mới để cập nhật!", "Thong Bao")
            txtTenChucVuMoi.Focus()
            Return
        End If

        chucvu.Ten = txtTenChucVuMoi.Text

        Dim chucvubus As New CChucVuBUS()
        Dim kq As Integer = chucvubus.CapNhatChucVu(chucvu)
        If (kq = 0) Then
            MessageBox.Show("Tên chức vụ này đã có", "Thong Bao")
            Return
        Else
            MessageBox.Show("Đã cập nhật thành công!", "Thong Bao")
            Reset()
            dgvDanhSachChucVu.Rows.Clear()
            Dim listchucvu As List(Of CChucVuDTO) = New CChucVuBUS().LoadDanhSachChucVu()
            stt = 1
            For Each cv As CChucVuDTO In listchucvu
                dgvDanhSachChucVu.Rows.Add(stt, cv.Ma, cv.Ten)
                stt += 1
            Next
            Return
        End If

    End Sub
End Class